// pages/shoplist/shoplist.js
Page({

  /**
   * 页面的初始数据
   */
  data: {
    query: {},
    shopList: [], // 商铺列表数组
    page: 1,  // 页码
    pageSize: 10,  // 每页请求的数量
    total: 0, // 总条数
    // ==== 页面状态类的数据 =====
    isLoading: true,
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    console.log(options)
    // 设置页面query参数
    this.setData({
      query: options
    })
    // 发起网络请求
    this.getShopList()
  },

  // 获取店铺数据
  getShopList(cb){
    // 展示加载框
    wx.showLoading({
      title: '数据加载中...',
    })
    // 请求开始前，设置页面的加载状态
    this.setData({
      isLoading: true,
    })

    // 请求店铺列表数据
    wx.request({
      url: `https://applet-base-api-t.itheima.net/categories/${this.data.query.id}/shops`,
      method: 'GET',
      data: {
        _page: this.data.page,
        _limit: this.data.pageSize
      },
      success: (res) => {
        console.log(res)
        // 设置页面数据
        this.setData({
          shopList: [...this.data.shopList, ...res.data],
          total: parseInt(res.header['X-Total-Count'])
        })
      },
      // 网络请求完成（成功或失败都要走）
      complete: (res) => {
        // 关闭加载提示框
        wx.hideLoading()
        // 请求结束，设置页面的加载状态
        this.setData({
          isLoading: false,
        })

        cb && cb()
        // 判断type类型
        // if(type === 'xiala'){
        //   wx.stopPullDownRefresh()
        //   // xxx
        // }
      }
    })
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {
    wx.setNavigationBarTitle({
      title: this.data.query.title
    })
  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {
    // console.log('重制请求数据')
    this.setData({
      shopList: [],
      total: 0,
      page: 1,
      pageSize: 10,
      isLoading: true
    })
    // 发起请求
    this.getShopList(() => {
      console.log('yyy')
      wx.stopPullDownRefresh()
      console.log('xxx')
    })
  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {
    console.log('触底了')
    // 当前查询条件的数据是否全部返回
    if(this.data.shopList.length === this.data.total) {
      // return console.log('数据加载完毕了')
      // console.log('数据加载完毕了')
      return wx.showToast({
        title: '数据加载完毕！',
        icon: 'none'
      })
    }


    // 当前请求数据是否返回的判断
    if(this.data.isLoading) return
    // 数据返回以后再触底才执行下一页的请求
    console.log('触底了，请求数据')
    // 修改请求参数
    this.setData({
      page: this.data.page + 1
    })
    // 继续发起请求
    this.getShopList()
  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})